#### ESECUZIONE ISTRUZIONE

L'IP DENTRO HA UNA SEQUENZA DI BIT! QUESTA SEQUENZA DI BIT VIENE INTERPRETATA CONE INDIRIZZO.

La mudiarza di memoria dove è consenura la prossima istruzione da eseguire.

Program Counter (PC), ovvero il contatore delle istruzioni, contiene l'indirizzo della prossima operazione da eseguire.

Instruction Register (IR), il registro delle istruzioni, contiene l'istruzione da eseguire.

| AL<br>By 7<br>que | RIP 100  addw %ax, %bx 100  be & Undirizzor.  L'INDIRIZZO 100 TROVERO UN INSTERME di  TE. (100 & Undirizzo doue e contension la projecta in intruzione).  Esta isruzione viene relevanta dolla  moria e messa nell'IR l  MEMORIA |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | Durante la fase di fetch, l'istruzione viene copiata<br>dalla memoria di lavoro nell'IR                                                                                                                                          |
| R                 | P 100 addw %ax, %bx 10                                                                                                                                                                                                           |
| II.               | addw %ax, %bx                                                                                                                                                                                                                    |

DA ORA IN POI, TUTTO IL PROCESSORE PUÒ LEGGERE LA CODIFICA BINARIA DELLA MIA ISTRUZIONE MACCHINA, DALL'IR.

MEMORIA

Neur fase di decale, in survione du bit de la CU lappea dall'Il, divennimenta quali sono le risorze di calcolo che devono essere socilizzate per andoru ad implementare la semantica di quiz'istrome.



Ci souci un segnale di controllo che abiliterà la scrittare sul registro destinazione. (La veducero)

L'IP VIENE INCREMENTATO IN CIASCUNA FASE DI FETCH.

21:13

core si FA?



INCREMENTO DEL RIP CON SOMMATORE DEDICATO.

INCREMENTIAMO DI UNA CERTO CUANTIDA

DI BYTE LA QUANTITA DI RIP.

Patrei d'AC: PERTO IL velore di 19 IN UN REGISTRO 1, IL VALOVE della gluantità di ByTC da Sommere Nel Registro 2, force la somme con l'alu, e il risultato METTERIO IN 19. E ve penissimo V.
(I MOBLEMEN è de c'un operazione lenge : perchè ho due Registri Temporame i doventi alla un ALU.

Significa:

- 1. COPIANO RIP IN UNO DEI REGISTRI TEMPORANCI;
- 2. SCRIVERE NELL'ALTRO REGISTRO TEMPORANCO L'INCREMENTO;
- 3. IL RISULTATO VIENE RISCRITTO DENTRO RIP;

Percopiù questi a passi li donei suologne per l'encreionis di agui , struzion

### NON YA BENE, SI USA INVECE UN ADDER DEDICATO!

(INTERNO al RIP)

Realizziamo II Aegista (RIP) come un registro a Incremento ! E un registro de ha I sui flip flop che montengono I date, E contiene al SIO INTERNO UN sommature dedicato.

ALZANDO UN SEGNALA di CONTROllo, quello sommatore dedicato, mi reamittura di incrementara RIP.

CHIARAMMENTE deux avere anche un Buller Three-state in uscita perché deux scruere rer augiornaire sul Bus q: sistemme condiviso;

ORA, CHE (i facio con l'incremento di RIP?

UNO VOlto che lo so il valore di RIP lo dero Transpoire adla memoria, con lo scoro pai di andorci a prelevore il codire macchino dell'isperiore da mistore in IR.
VADO SULA MEMORIA TRAMITE IL BUS QI SISTEMA. Cuerso la memoria)

le ora immette il valore di RIP nel DATA BUS.



Dopo che ho serto qui il velore di RIP deve convettersi con il BUS di sisteme che va verso la memoria.

Devo commente questi 64 fli, con i 64 fli che escono dal processore e vanno verse la mentra

NON E CHE POSSO ATTACCORCE I GILI. INTERNO!

← Giusto per capire: Siamo na questa zona.

BUS di sistema.

IL BUS disistema Riguarda anche i dolli, le istruzioni che Trasferisso de e

Devo sviluppore un circure che mi consenta di cellegere il DATA RIS col BUS Di SISTEMA.

IL DATA BUS È UNO, IL BUS di SISTEMA è composta da RUS Indirizzi e DATI.

Silcohe le devo trassperire alla memorcia un indirizzo (Lottura) e un dato (SCAITURA)

Devo svirare un modo di disaccoppiare il olatabus interno al processore con 2 bus
dillerenti che vanno verso la memoria.

IN PIU la mumoria è luita, perció devo montenera l'suformazione singue rer TUTTO la durata dell'operazione.



ole interno di Ir.

## ABBIANO DUE REGISTRI: HAR & MOR;

Mar = Memory Address Register

Mar = Memory Data Register

PERché abbiennes un aus di mudirizi e un aus desti; IL DATO VA SCRITTO NERO MOR. L'IMBIRIZZO NELL'MAR. I DUE REGISTRI SONO A 64 bot.

# ALLORA: NEL DATTA BUS INTERNO DELLA CPU, TRANSITA IL VALORE DEL RIP, E DEVO ANDARE IN HEMORIA FER PRELEVARE

L'ISTRUZIONE SUCCESSIVA. Dopo aver abilitato il buller three-state per multipre sul databas interno il contenuto dell'ISTRUCTION POINTER, Abiliterò il segule di scrittura sul MAR. A questo punto ho una copia nel RIPIN MAR, A questo punto ho una copia nel RIPIN MAR, A questo punto l'indirizza dell'Istruzione successiva e conservata all'interno di MAR e per cleva gave gluire il contenuto chi questo registro verso la mamoria. Abilitando il buller three-state!

Dopo TOT di tempo scriverà sul data 1865 Il dato del codice machina e avoirenonno quelli bit sul mumory data 1865. Devo gorme una copia per pei scrivollo nelli 1972.

Abilitando Il Buller-three state, abilito la scritura SU MDR.

E TRASJERISCO IL CONTENUTO di MOR SUL BUS INTERNO, e così la POSSO SCRIVORE

## SCRNO IL VOLORE di UNA VARIABILE CONTENUIA IN MEMBRIA:

Posso scrivere qualsias date provenione dall'interial data Rus in MDR.

Questo significa trasferire un date dal papistro alla minaria;

SCRIVERO IL DATO SU MDR PARIENDO DALL'INTERNAL DATA BUS AER MANdorlo sul mumory DAM BUS, SCANDO IL MIO DATO SULL'INTERNAL diata BUS, e questo dato può provende da un Registro di uso gunerale o lo scrivo su MDR ... e la mando verso la memoria !

MDR & UN REGISTRO BIDIREZIONALE CHE FUNZIONA DA AMOGGIO PERTUTI I
TRASFERIMENTI DI MEMORIA.

COME for la menoria a capite se deve laggue dati dal MEMORY DATA BUS O SCRIVERE DATI SUL MEMORY DATA BUS?

GUELO DICE IL PROCESSORE SPRUTTOMOLO IL BUS di CONTROLLO

SUI MEMORY CONTROL BUS derro prevadure almeno due segrali di controlo: MRD, MWR. MEMORY Read e MErmory WRITE!

Se reglier survere sulla memoria, scrio il mio indirizzo sur MAR e ARILITO
IL BURGER THREE STENDE, mando l'indirizzo alla memoria,

Dopo andr skitto il dato che vaglio skriere in memorcia, INMDR, ABILITO anche il Reller 2, così la memorcia riceve anche il olato che dere skrivere, A quell'purio a Biuto il sacurale MWR chiedo alla memorcia di prendere i diati che viaggiano sul memory data 85 e skriveri A quell'udi Rizzo su MAR.

Se vaglio reggire dalla memoria, mitto un indirezzo sul mumary adeleso lus, ABILITO MRD, A quel punto la mia mumoria survera i date sul mumoria data lous, ABILITOUNDO IL BULLER Three state e al seguale di virire, faccio una copia interio al Processore;

LA CU CHE GESTISCE IL TUTTO!